Throughput - number of instructions done per cycle or per unit time Latency - amount of time it takes to finish an instruction

3.
to keep track the instruction executed and the input data needed by each stage of the pipeline

- to store the output data correctly to its proper memory address/register

4.

|      |               | EX         |            |           | MEM    |              |             | WB           |              |
|------|---------------|------------|------------|-----------|--------|--------------|-------------|--------------|--------------|
|      | Inst.<br>Type | ALU<br>Src | Reg<br>Dst | ALU<br>Op | Branch | Mem<br>Write | Mem<br>Read | Mem<br>toReg | RegW<br>rite |
| add  | R             | 0<br>RF    | 1<br>rd    | ADD       | 0      | 0            | 0           | 1<br>ALU     | 1            |
| load | I             | 1<br>imm   | 0<br>rt    | ADD       | 0      | 0            | 1           | 0<br>Mem     | 1            |
| bne  | 1             | 0<br>RF    | Х          | SUB       | 1      | 0            | 0           | Х            | 0            |